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A GENERALIZATION OF THE TRIE DATA STRUCTURE 


Richard H. Connelly and F. Lockwood Morris 

Abstract. Tries, a form of string-indexed look-up structure, are generalized to per¬ 
mit indexing by terms built according to an arbitrary signature. The construction 
is parametric with respect to the type of data to be stored as values; this is essen¬ 
tial, because the recursion which defines tries appeals from one value type to others. 
“Trie” (for any fixed signature) is then a functor, and the corresponding look-up 
function is a natural isomorphism. 

The trie functor is in principle definable by the “initial fixed point” semantics 
of Smyth and Plotkin. We simplify the construction, however, by introducing the 
“category-cpo”, a class of category within which calculations can retain some domain- 
theoretic flavor. Our construction of tries extends easily to many-sorted signatures. 


Section 1. Introduction. 

A look-up table—a finite data structure intended for the retrieval of values which 
have been stored corresponding to “keys”—is naturally regarded as a concrete im¬ 
plementation of what abstractly is a function from keys to values, but just what 
sort of function deserves some consideration. If the value type is A, which for 
convenience we shall think of as always containing a distinguished element or base 
point *a —we call such a type a pointed set —and the key type is Y, we may say 
that a table models a function from Y to A whose value is *a (representing the 
absence of a genuine value) for all but finitely many arguments; we introduce the 
notation A ^ for the set of all such functions. 

Tries [4,6] are a form of look-up table suited to the situation where keys are 
strings over a finite alphabet. Our innovation here will be to extend the possible 
sets of keys from “strings over any finite alphabet” to “terms built with any finite 
signature of operators”. We begin by giving a description of ordinary string-indexed 
tries (omitting optimizations found in more practically-oriented treatments) in such 
a way as to make the generalization to indexing by terms as obvious as possible. 

Let H be the set of finite strings over a finite alphabet {ci,..., c m _i} for any 
m > 1. (To be sure, if m is one, H contains only the empty string, but there is 
no reason to forbid that case.) An H- indexed, A-valued trie is a finite (m — l)-ary 
tree, its nodes labelled by elements of A. (We shall be wanting to consider tree 
nodes as ra-tuples, with the label as mth component; this accounts for our taking 
the size of the alphabet to be m - 1.) A trie is searched by the evident recursive 
principle: the empty (m — l)-ary tree, which we denote by • (pronounced “spot”), 
represents that function in A^ whose value is *a for every string, while an m-tuple 
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(ri,..., r m _i, a) represents the function whose value at the empty string is a and 
whose value at a non-empty string c L h is the value at h of the function represented 
by n. 

To put this more formally, we may regard H as a term algebra: the set of all 
terms which can be built with m — 1 unary operators (“prefix Ci”) and one nullary 
operator (“empty string”). [This is more often called a “word algebra”; we go 
against convention because we shall be wanting “word” in a distinct technical sense 
in Section 4.] To make a specific construction, we may, following Reynolds [9], 
define H as the least solution of the set equation 

m 

H = (if * < m then H else {()}) 

Z— 1 

where by the summation notation we intend the following specific disjoint union of 
sets: 

TO , r 

YY,Zi = {{i,z)\l <i<m and z 6 Zi}. 

i= 1 

Here {()} is a convenient one-element set—we take the zero-tuple for its element 
in the same spirit that we say the empty string is a nullary operator. Then, as is 
well known, H is explicitly given by H = (J n H n , where H 0 = 0, and for n > 0, 

m 

H n+ 1 = (if i < m then H n else {()}). 

(A remark on notation: We will be doing a lot of indexing from zero to infinity; 
we therefore will write things like \J n H n as shorthand for U n >o H n .) Given this 
construction of H , we can write an explicit recursive program for the look-up or 
“apply” function: 


ap ® h — ^ 

ap (ri,...,r m _i,o)(m,()) = a 

ap (ri,..., r m _i, a)(i, h) = apr^ h for 1 < i < m. 

Before leaving the case of strings as keys, we give a more rigorous, and also 
slightly more restrictive, definition of the set of H-indexed, A-valued tries. Note 
that our first description, that a trie was any A-labelled (m — l)-ary tree, allowed 
the everywhere-*^ function to be represented not only by •, the empty tree, but 
also by any tree all of whose node labels were *a- We now decide to require that 
• be the only allowed representation for this function, so as to get a one-to-one 
correspondence between the functions in and their representing tries. To this 
end we introduce a modified Cartesian product (called “spot product”, if this 
is not too cutesy) defined for any m pointed sets by 

m , f rn 

ti.Ai = n^i-{(*A 1 ,.--,*A m >}u{»} 

i=l i =1 

with • taken to be the base point of the resulting set. 
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Now we can say that our set of tries is the least solution to the set equation 

m 

R = n.af i < m then R else A) 

i— 1 


and is given explicitly by 

Ro = {•} 

m 

^n +1 _ II. Of i < m then R n else A) 

i= 1 

R = (J R n • 

n 

The reader will have noticed the parallelism between the constructions of R and 
H, and may foresee that the one-to-one correspondence between R and will 
prove to be a consequence of a “law of exponents” which we give as: 

Proposition 1.1. If X\, ... , X m are sets, m > 0, and A is a pointed set, then 
there is a one-to-one correspondence 

Pm : A [Xl] x • • • x A [Xm] = A [Xl+ '" +Xm] 


given by 


hm • (^1 j • • • 5 9m ) H4 A (i,z).giz, pj- : f <-»• aq),..., Ax m ./(m, x m )). 

Proof. We know that the formula for pm gives a one-to-one correspondence for 
unrestricted functions, p m : A Xl x • • • x A Xm = A Xl+ '" +Xm - this is the coprod¬ 
uct property of the ra-ary disjoint union in Set. We have only to notice that 
this correspondence cuts down to the alniost-everywhere-*^ functions: we have 
(gi, • ■ • > 9m) £ A^ Xl ^ x • • • x A^ Xm ^ if and only if, for i = 1 , ... , m, each gi X{ ^ *a 
just for some finite set of values of Xi, say for X{ € {xn, ..., Xi ni }; this is the same as 
to say that pm(gi ,..., < 7 m )(i, z) = (A(*, z).gi z){i, z) is different from *a just for (i , z) 
one of the finite set of values {( 1 , rrn),..., (l,xi ni ),..., (m, x m i),..., (m,x mnm )}, 
he., that Pm(9i, • • -,9m) G A [Xl+ '" +Xm] . □ 

For any set Y and pointed set A we take *^y] to be the constant function A y.*A- 
We may then observe further that the correspondence p m is base point preserving. 
Also, there is an evident base-point-preserving, one-to-one correspondence between 
the modified and the ordinary Cartesian products of A^ Xl \ ... , A^- Xm h Composing 
these correspondences, we may record for later reference: 

rn 

Definition 1 . 2 . Denote by p* n : A^ Xt ^ = the base-point-preserving, 

i— 1 

one-to-one correspondence 


• ■ * A (i,z).* A 
(9l,---,9m) ^ X(i, z).Qi z . 
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We have just seen string-indexed tries presented with strings taken to be the 
elements of a particular term algebra. We now generalize to keys which are the 
elements of an arbitrary term algebra, first one-sorted and then, in Section 4, many- 
sorted. A term algebra is characterized by its operators, say m of them; the only 
significant property of each operator is the number of operands it expects (its arity ), 
a non-negative integer ki for i = 1, ... , m. Thus, following Reynolds [9], we may 
take our generic one-sorted term algebra to be the least set T solving the equation 

771 

T - 

i— 1 


namely 

i m 

T = |Jr n , where T 0 = 0 and T n+1 = J2 T n ■ 

n i:=X 

The key to generalizing the trie idea, still obtaining a set in one-to-one corre¬ 
spondence with A^ T \ in the presence of operations of unrestricted arity is another 
law of exponents. 

Proposition 1.3. If X , X k are sets and A is a pointed set, then there is a 
one-to-one correspondence 

u k : A [Xk] "' [Xl] “ A[Xix -xX k ] 


given by 


v k :g^ A(a?i,..., x k ).gxi ■ ■ - £fc, v k 1 : f ^ \ Xl ■ ■ ■ \x k .f(xi ,..., x k ). 

Proof. We treat first the case k = 2 , that is v 2 '■ A^^ = A^ XxY \ For functions 
without restriction, this is the “uncurrying” isomorphism, part of the Cartesian 
closed structure of Set. Again, we have only to check that it cuts down to the 
almost-everywhere-* functions. Suppose / = u 2 g, and suppose that / € A^- XxY \ 
i.e., that for some N we have f(x,y) ^ * A only for (x, y) 6 {(£ 1 , 2 / 1 ),..., (a:jv, 2/jv)}- 
Then gx ^ only for x in the finite set (possibly with fewer than N elements) 
{£ 1 ,..., £;v}, and even when x is one of these, gxy 7 ^ * A only for (x, y) in the set of 

N pairs, so that g x 6 A^ in all cases, and g <G Conversely, if g € 

then g x 7 ^ *^[y] only for x in some finite set {£ 1 ,.. .£m}, and for i = 1 , ... , M, 

gxiy ^ * A only for, say, y e { 2 /ii, • • •, 2/inJ, which is to say that v 2 g(x,y) ± * A 

only for the n x -I- 1 -n M pairs (£ 1 , 2 / 11 ), ... , (£M, 2 /Mn M )> so that g £ A^ XxY \ 

Now we may treat general k > 0 by induction. For k = 0, it is immediate that 
vo : A = AdO>] ? where u 0 a = A{).a, and u^ 1 f = /(). Then supposing inductively 
that any u k has been shown to be a one-to-one correspondence, we may observe 
that z'fc+i is the composition 

r y' 1 

^[X fc+ 1 ]”d*2 ] 1 1J A [x 2 x-xX k+1 ]l x d A \x 1 x{x 2 x-xX k+1 )\ 
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of which each step is a one-to-one correspondence (the instance of m the middle 

fv 1 

step is with X = X\, Y = X 2 x • • • x X k+ i) since following any g G 1 

from left to right we find 

g i->- Xx 1 X(x 2 , • •. ,x k+1 ).gxi ■ ■ ■x k +i A(a:i, ( x 2 , • • •, x k +i)).gxx ■ ■■x k+ 1 

^ X(x u ...,x k +i).gx 1 ■■■x k+1 = v k+l g. □ 

A generalized trie has to represent a function whose values are functions. That 
is, an ordinary trie and its sub-tries all represent elements of A^ H \ whereas a gen¬ 
eralized trie and its parts have to represent elements of A\ t \ = A[ TxT i, 

[rpl 

etc. But we can think of A^ , for example, as two iterations of [ r i” at the 
set A; so if we can abstract on the type A, and regard the generalized trie idea as 
a scheme for representing functions from T to any type, then we should be able to 

iterate this scheme twice at A to get a representation of A\ t ^ T \ This motivates 
the following definition of the set of T-indexed, A-valued (generalized) tries, where 
now A is an explicit parameter ranging over pointed sets: 


Ro(A) = {.} 

Rn+i(A) = Y[.Rt\A), 
i —1 

here R^\A) denotes R n (... ( R n (A ))...) with ki iterations of R n , and 

R(A) = {jR n (A), 

n 

with *r(a) — • independent of A. When ki = 1 for i < m and k m = 0 , R(A) 
reproduces the string-indexed tries as previously defined (that is, R(A) — R). 

As an example term algebra let us take binary trees. We simulate a one-bit 
label on each node by providing two binary constructors; that is, we take m = 3, 
k\ = 0 (to construct the empty binary tree), k 2 = k$ = 2 ; we may express this 
more comprehensibly as the recursive set definition 

Tb = {()} + Tb 2 + Tb 2 . 

Then the Tb- indexed, A-valued tries have the corresponding recursive definition 

Rb(A) = A x Rb(Rb(A)) x Rb(Rb (A)). 

To actually make an example of a trie, let Z* = f Z U {*}, that is the inte¬ 
gers extended with a base point; then the function from Tb to Z* that maps 
the one-node binary tree (2, ((1, ()), (1, ()))) to 7 and the two-node binary tree 
(2, ((1, ()), (3, ((1, ()), (1, ()))))) to 8 , everything else to *, is represented by the trie 
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Returning to the general treatment, it seems intuitively reasonable to suppose 
that the following equations define a family of look-up functions, also parameterized 
by the pointed set of possible values, and similar to what we had in the string- 
indexed case but more recursion-intensive: 


apA • t = * A 

apA {t x ,... ,t ki }) 

apA(apfl(A)( - ' ■ (ap#(*i-i)(A) ^1)' ’ ) —1) • 

Note that values of i for which k t = 0 correspond to nullary operators, that is 
constants, of the term algebra; for such i we have 

apA ()) = tv 

It is by encountering a nullary subterm that ap is able to take a step towards 
escaping from its apparently ever-more-deeply-nesting recursion. 

It may be easier to make sense of ap specialized to our binary-tree-indexed 
example, which comes out as 


B-ap A • b = * A 
B-ap A (r 1 ,r 2 ,r 3 )(l, ()) = r x 

B-ap_ 4 (ri, r 2> r 3 )( 2, {b Xl b 2 )) = B-ap A (B-ap fiB(A) r 2 b x ) b 2 
B-ap A (ri,r 2 ,r 3 )(3, (b x ,b 2 )) = B-ap A (B-ap fls(A) r 3 b x )b 2 . 

The reader may care to verify that B-ap z actually will return 7 and 8 from the 
example trie for the appropriate two binary trees as keys, and * for other keys. 

We will prove, by the end of Section 3, that this ap actually is well defined. 
(In reality, of course, one wants to implement ap as a single subroutine, not an 
infinite family. Apparently, all ap really needs to know about the type at which 
it is supposedly working is the relevant base point which it might have to return. 
Thus a practical program might be 

ap '(bp, »)t= bp 

ap '(bp, (ri,... , r m ))(t, (h, ...,t ki )) = ap '(bp, ap'(», • • • (ap'(«, n) t x ) ■ ■ ■) t ki -i) t ki • 

In situations where it can be arranged that • and * A are identical, even the pa¬ 
rameter bp would be unnecessary. We shall, however, not pursue this line further, 
preferring to keep the value type as a parameter.) 

Stated in terms of sets, what we hope to establish, in order to show that the 
generalized tries really do represent finite functions, is a one-to-one correspondence 
R(A) = for every pointed set A. In outline, the proof goes as follows: For 
any set Z, write Tz for the set-to-set mapping A i—> A^; then Proposition 1.1 and 
Proposition 1.3 will yield 

n .Ff'\A) = ^ Er „ Z .,,(A) for all A. 

i=1 
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Then we may hope to prove by induction that for all n > 0, 

Rn(A)^^ Tn (A) = A^. 

For n = 0, {•} = A™\ as an inductive step, calculate 


R n+ M )= n as n.4!‘’o) = T -‘M) = o) = ^ IT - + ‘'- 


:(ki) 


(ES=i Tpy 


i=1 i=1 

One would then like to conclude that, in the limit 


R(A) = |Ji2 n (A) “ = a [ t] . 

n 

Making this calculation rigorous, and showing that the family of one-to-one corre¬ 
spondences R(A) = A^ it yields is in a suitable sense the least fixed point of the 
recursion equations for ap, will be the purpose of the following two sections, with 
assistance from the appendix, where we have segregated such necessary definitions 
and theorems as belong entirely to category theory. 

Not surprisingly, we are able to view the T introduced above as a (Curried) two- 
argument functor, having its second argument and its result in the category Set* 
of pointed sets and base-point-preserving functions, but taking its first argument 
(the Z in A^) from the partial order of sets and set inclusions. By this choice 
for its domain, we are able to define T so as to be covariant in both arguments, 
and are spared the difficulties which led Smythe and Plotkin in [11], needing a 
covariant arrow bifunctor within a category of domains, to introduce a subcategory 
with “embeddings” as morphisms. Nevertheless, T bears some resemblance to an 
exponential functor, and the isomorphism of Proposition 1.3 is much the same as 
that which gives Set* with smash product as a tensor product—or equivalently the 
category of sets and partial functions with Cartesian product as tensor product—its 
monoidal closed structure (see, for example, Poigne [8]). 

The function R which constructs for any A the T-indexed, A- valued tries is in 
fact an endofunctor of Set* . Moreover, ap is a natural isomorphism from R to the 
functor — fC, as we shall show. The formula given above for the construction of 
each R n +\ from R n amounts to the definition of an endofunctor 7 Z of Setf et * , of 
which R is an “initial fixed point” as defined by Smyth and Plotkin [11]. 

It is because the definition of ap^ appeals to ap^(^), etc.—in other words, be¬ 
cause ap must be polymorphic to work at all—that we are compelled to look for a 
whole functor, rather than a single data type, to be an initial fixed point. 

It was originally our intention to carry out the rigorous construction of R and the 
natural isomorphism ap as a straightforward application of the Smyth and Plotkin 
method, which generalizes the familiar “least fixed point of a continuous function” 
construction from domain theory to a categorical setting. However, it has turned 
out that, despite the presence of categories and functors, the trie construction re¬ 
tains a very domain-theoretical flavor, because the sets R(A) are unions of inclusion 
towers, as is also the set T of terms. It therefore has seemed to us worthwhile to 
make a preparatory digression, introducing in Section 2 a kind of domain-category 
hybrid, the “category-cpo”. This will allow our desired natural isomorphism of 
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functors to be constructed (in Section 3) as the least upper bound of an ascending 
chain rather than, as would be done by a more general category-theoretic treatment, 
as the colimit of a general w-sequence of objects and morphisms. 

There seems to be a growing recognition that category theory is relevant not 
only to semantics, but to the more mundane algorithms-and-data-structures side of 
computer science. Spivey [ 12 ], for example, uncovers natural transformations and 
adjunctions in familiar list-processing functions. It may not, however, be generally 
appreciated that the construction of even a first-order data type can, as here, call 
for categorical methods. The present paper uses rather a lot of mathematics to 
arrive at a modest algorithmic result, but we hope that some of the tools developed 
here will be reusable in other applications. 

Section 2. The notion “Category-cpo”. 

It is a commonplace observation (see for example [7, p. 11 ]) that a partial or¬ 
der may be regarded as a category in which each hom-set contains at most one 
morphism, and which moreover is skeletal: isomorphic objects are identical (this, 
together with the uniqueness of morphisms, entails that the only isomorphisms are 
the identities). For a category which in this way “is” a partial order, C, on its 
objects, we will, when a and b are objects such that a Q b, write (a C 6 ) as a 
notation for the (unique) morphism. 

Definition 2.1. A category-partial order (category-po for short) is a pair (K,C) 
where K is a category and C is a subcategory of K which is a partial order on all 
the objects of K, and such that the identities are the only morphisms of C that are 
isomorphisms in K. 

The morphisms of the subcategory □ will be called the “inequalities” of K. Note 
that this usage of “inequalities” includes also “equalities”, i.e., identity morphisms. 
The last condition in the definition is equivalent to requiring that the insertion 
functor i : Q — * K reflect isomorphisms [7, p. 150], since no non-identity is an 
isomorphism in C. We will never have occasion to consider more than a single 
partial-order subcategory of any one category K\ hence, by abuse of notation, we 
will generally write just K and not (K, C) as our name for the category-po. 

In any category-po ( K , □) a partial order is induced on all the morphisms of 
K , as follows: if / : a —> b and g : c — * d , we write / □ g (using the same 
partial order symbol as between objects) just in case a C. c, b □ d, and we have 
the commutative square 


( 1 ) 


a Cl c 


/ 


9 


b 1= d. 


Verification that □ between morphisms is a partial order is immediate. This partial 
order is identical with the comma category iji. Since * reflects isomorphisms, so 
does the insertion from i[i to IkIIk- Consequently, Ik [Ik is also a category-po. 
It is also immediate, for any objects a and b, that a □ b if and only if l a jZ lb- 

Composition in a category-po is monotone where defined: if a —b c and 
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f' 9 ' 

a' -!—> b' d are such that / □ /' and g □ g 1 , then g o f □ g' o /', as one sees by 
pasting the squares together. 

A noteworthy elementary fact is the following: 

Fact 2.2. In a category-po, if f,g:a —> b with f C g, then f = g. 

This is because the commuting square by virtue of which it holds that / C g 
must have l a and 1& for sides. (This observation makes it clear that category- 
pos are very unlike typical categories of domains and continuous functions: in a 
category-po, all the non-trivial instances of “approximation” of one morphism by 
another must be between morphisms from different hom-sets. A motivation for the 
development of category-pos may be taken from the familiar observation that if / 
and g are (graphs of) two total functions with the same domain, then / C g implies 
/ = 9 ‘) 

We now introduce the principal notion with which we intend to work. 

Definition 2.3. A category-po (K, C) is a category-complete partial order (for 
short, a category-cpo) if C is co-complete (that is, every ascending co-chain of objects 
has a l.u.b.) and each such l.u.b. is an ui-colimit in K. 

The requirement that each cn-l.u.b. be a colimit is identical to requiring that the 
insertion functor i : C —► K preserve cn-l.u.b.s as colimits. (We should remark 
that a category-cpo is a special case of a “double category” as defined by MacLane 
[7, p. 44], since the instances of □ between morphisms are certain commutative 
squares in K\ however, we do not know how to apply this observation.) 

Notational remark: We use the tuple brackets (—) , with a binding occurrence 
of n indicating as with (J and the like that n runs from zero to infinity, as a notation 
for infinite sequences and especially ascending chains. For example, as a synonym 
for “sequence ko □ k\ □ &2 E ■.. of objects” we may write “u;-chain of objects 

The next lemma shows that the insertion functor i : C —> K reflects [7, p. 150] 
colimits of w-chains. 

Lemma 2.4. Given a category-cpo K, let k be an upper bound of an co-chain 
ko E ki □ • • • of objects of K. If (( k n C kyj is a colimit cone, then k = |_| n k n . 

Proof. Since (|J n E k) mediates from colimit cone (( k n □ U n.kn)) n to cone 
((k n □ k)) , it must be the unique mediating morphism (u.m.m. for short). Since 
((k n E k)) is also a colimit cone, ([J n k n C k) is an isomorphism and so must be 
an identity. □ 

The product category of a family of category-epos is a category-cpo using the 
componentwise ordering and l.u.b. The following proposition shows that the mor¬ 
phisms in a category-cpo are w-complete. 

Proposition 2.5. Let K be any category-cpo. The morphisms of K are in¬ 
complete using the ordering defined by Diagram 1. Specifically, for any co-chain 
(fn ■ a n —♦ bn) n , there is a l.u.b. |_| n f n : U n — > LL h n- 

Proof. Consider (f n ) n as a sequence ((a n , b n , f n )) n in i{i. Theorem A.4 gives that 
P : i[i — ♦ K x K creates a colimit object (|J n a n , |J n b n , /). The morphism / is an 
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upper bound of (/ n ) , because the created colimit cone is (((a n E U m a m),(&n E 
Um bm))) n - To see that / is the l.u.b., let g : c —* d be any upper bound of (fn) ■ 
Since (c, d , < 7 ) is a vertex of ((a n . b n , /„)) , Fact A.l applied to the functor P gives 
that ((Un a ™ E c),(U„ 6 n E d)) is the u.m.m. from (U„ a n, Un b n , /) to ( c,d,g). 
That is, / E g. □ 

Fact 2.2 gives the following useful fact. 

Fact 2.6. If g : |_| n a n —> IJn b n is an upper bound of an co-chain of morphisms 
(fn ■ a n —* b n ) n , then g = \J n /»• 

It follows from Fact 2.6 that li i a = | L 1 0 for an E «i E ao C • • • . It also 
follows that composition of morphisms is cj-continuous: by monotonicity, |J n 9n ° 
Un /n E 9nO f n for each n- therefore, by Fact 2.6, Un 9n ° U„ /» = U n (9n ° fn)- 

For any category-epos L and A, we say that a functor F : L —> K is continuous 
if and only if F preserves inequalities [ F(a E o) = (Fa E Fa) ] and is cn-continuous 
on objects [ f r '(U n a n) — U n F(a n ) ]. (“Continuous” seems the only reasonable word 
to use in our context. Note, however, that this is not cn-continuity of functors as 
ordinarily defined, that is preservation of all u-colimits.) 

Any continuous functor F is w-continuous on morphisms: First, F is monotone 
on morphisms: an instance of E between morphisms, say 


a □ a 


f 


f 


b E b, 


is sent by F to 


Fa -g° =C > 


Ff 


Fd 

I Ff 


Fb F(Q ~~> Fb. 


Then, for any chain of morphisms (f n : a n —> b n ) , monotonicity gives that 
^(Un/n) 3 F(fn) for each n. Since F(\J n f n ) : F(U n o n ) = U n F M —♦ 
F (Un 6n) = Un F(b n ), Fact 2.6 gives F(U n /„) = Un F(fn). 

For any continuous functors F,F':L —> K, let r : F — F' be any natural 
transformation. For any a E a in L, we have the commutative diagram 


Fa - > F'a 


F{ Q=E 
Fd 


E'(C)=C 


-> F'a. 


That is, a E a implies r a E T a- For an u;-chain (a n ) n in L, it follows that ry an □ 
T an for each n. Since the domain of ry an is F(U n On) = UnT’(nn) an d the 
codomain is F'([_\ n a n ) = \_\ n F'(a n ), Fact 2.6 gives T\j nClri = Un T «r,- That is, any 
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natural transformation between continuous functors is a ca-continuous map from 
objects to morphisms. 

Clearly, functor composition preserves continuity. 

Let L be any (index) category and K be any category-cpo. Define a partial order 
Z between functors from L to K by 

F Z F O FI Z FI for every object / and Ff Z Ff for every morphism /. 

This is the same as to say that the assignment 1 i—» (FI Z FI) is a natural transfor¬ 
mation from F to F. If (F Z F) is an isomorphism, then each component (FI Z FI) 
must be an identity, making (F Z F) an identity transformation. Thus the trans¬ 
formations IZ as inequalities make K L into a category-po. The next proposition 
shows that K L is a category-cpo. 

Proposition 2.7. Let L be any category and let K be any category-cpo. The 
category K L is a category-cpo using the Z ordering. Specifically, for any uj-chain 
(F n : L —+ K) n , the l.u.b. is (|_| n F n )(0 = LI n F n (I) for each object l and 
(LiTn)(A) = U„-f» (h) for each morphism h. Further, if L is a category-cpo 
and each F n is continuous, then |J n F n is continuous. 

Proof. By Fact A.3, the functor ** : K L —* K^ creates a colimit object F 
with colimit cone ((F n Z F)) where F(l) = |_| n F n (Z) f° r eac ^ °bj ect ^ For an Y 
morphism h, since F(h) □ F n (h) for each n, Fact 2.6 gives that F(h) = (J n F n (h). 
Let G be any upper bound of (F n ) n - Since |Z : i*(F) — * i*(G) is the u.m.m. in 
K\ l \ Fact A.l gives that it is also the u.m.m. in K L . That is, F C G and F is the 

l.U.b. |_ln Fn- 

Now let L be a category-cpo as well and suppose that each F n in the cj-chain 
(F n : L —> K) n is continuous. It needs to be shown that |J n F n is continuous. To 
show that |J n F n preserves inequalities, let l Z l, and calculate 

(|_| F n ) (/ C l) = |_|F n (J C l) = [_\(F n l C Fj). 

n n n 

Since ((U n -^n)(0 Q (Un F n )(l)) is an upper bound of the sequence of inequalities 
( FqIGFoI) Z (FilQFil) Z ••., Fact 2.6 gives us that also 

((U^)(0 e(U- f ")w) = U(F„icF„i). 

n n n 

To show w-continuity on objects, let Zo Z l\ Z ■ • - be an w-chain in L; then 

(U^)(U'™) = U^(U'») = ULF-i'”) = ULI^f'”*) = U(Lk") ('”>)• 

n m n m n m m n m n 

□ 

If K and L are both category-epos, we henceforth denote by K L not the cat¬ 
egory of all functors from L to K but the full subcategory thereof whose objects 
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are the continuous functors. Exponential objects given by this definition of K L , 
together with the products noted above, may be shown to make the category of 
small category-epos and continuous functors Cartesian closed. 

Let K , L, M be any category-epos. The composition functor o : M L x L K —> 
M k [7, Exercise II.6.3, p. 45] is continuous. To see this, again treating preservation 
of inequalities first, calculate, for any k G K (see [7, p. 43 eqn. 2] for the horizontal 
composition of natural transformations): 

[(H ±H)o(G± G)]k = H(Gk C Gk) o (H(Gk) C H(Gk)) 

= ( H(Gk ) C H(Gk)) o ( H(Gk ) C H(Gk)) 

= ( H(Gk ) C H(Gk)) 

= (H o G C H o G)k. 

Then for ^-continuity on objects (functors): 

(U H n O U G n ) (AO = □ (U G m (A:)) = □ □ H n (G m (k)) = \J(H n o G n (k)) 

n n n m m n n 

for every object k , and 

(U o U G„) (/) = U (U G m (/)) = U U ^(G m (/)) = U(^» ° G»(/)) 

n n n m m n n 

for every morphism /. 

Of particular use will be the n-fold composition functor o n : (K K ) —> K k 
which by induction is continuous. (Zero-fold composition picks out the identity 
functor on K .) If we write A n for the diagonal functor, defined for both objects 
and morphisms by A n (x) = {x,..., x). with the result an n-tuple—this notation 
leaves the domain and codomain of A n , in every particular use of it, to be inferred 
from context—then it follows that n-fold iteration, 


is, for each n > 0 , a continuous endofunctor of K K . 

It has been noted that Ik [Ik is a category-po when K is, and the reader may 
have surmised that the same holds with “category-cpo” replacing “category-po”. 
Here is a proposition that gives a more general condition under which a comma 
category is a category-cpo. First, for any category-epos L and M, any category 
K , and any functors T : L — * K and S : M —> K, the comma category T[S 
is a category-po, where we take the inequalities ((/,m,/) C ( l,fh,f )) to be the 
morphisms of the form ((l C I), (m C m)). 

Proposition 2.8. Let L and M be any category-epos and let T : L —* K and 
S : M —♦ K any functors where T preserves l.u.b.s as colimits. Then the comma 
category T[S is a category-cpo. Specifically, for any u-chain ((Z n , m n , f n )) n , and 

letting l = |_|n l n and m = |J n m n for conciseness, the morphism f in the l.u.b. 

(, l,m,f ) is the u.m.m. in K from ( T(l n □ l)) n to (S(m n C m)o/ n )^. Additionally, 
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if S preserves l.u.b.s as colimits and f n is an isomorphism for each n, then f is an 
isomorphism. 

Proof. Theorem A.4 gives that the forgetful functor P : TIS —> L x M creates 
a colimit object ( l,m , /) with colimit cone ((( l n C Z), (m n C TO ))) n - Theorem A.4 
also gives that / is the u.m.m. from ( T(l n □ Z)) n to (S(m n □ m) o f n ) n and that 
/ inherits the isomorphism property when S preserves l.u.b.s as colimits. 

To see that (Z, m, /) is the l.u.b., let (c, d, g) be any upper bound of ((l n , m n , fn)) n - 
Since ((Z C c), (m □ d )) is the u.m.m. in L x M, Fact A.l gives that it is also the 
u.m.m. in TIS. That is, (Z,m,/) O (c,d,g). □ 

Here is an analog to Fact 2.2 for comma category-pos. 

Fact 2.9. In any comma category-po TIS, if Q ( l,m,g), then f = g. 

This fact may be seen by realizing that the morphism ((Z, m, f) C (l, m , g)) is the 
identity (1;, l m ). From Fact 2.9 follows also an analog for comma category-epos of 
Fact 2.6: If an object of the form (|_| n Z n , [_| n m n ,g) is an upper bound of the chain 
((In, m n , f n )) n in T[S, then it is the least upper bound. 

The next proposition uses Lemma 2.4 to give a condition under which a functor 
whose codomain is a comma category-cpo is continuous. 

Proposition 2.10. Given a comma category-cpo TIS where T : L — > K and 
S : M —> K, let Q be any category-cpo and let F : Q —* T[S be any functor. 
If P o F is continuous, where P : T[S —> L x M is the forgetful functor, and T 
preserves l.u.b.s as colimits, then F is continuous. 

Proof. F preserves inequalities, because P o F does and P does not modify mor- 
phisms. Let 9 o ^ 9 i E "■ be any w-chain in Q. Since P o F is continu¬ 
ous, P(F(\_\ n q n )) is the vertex of a colimit cone (( P(F(q n )) C ^(-FXLL 9n)))) n - 
Since, by Theorem A.4, P creates colimits, Corollary A.4.1 gives that (( F(q n ) C 
F(U n Qn ))) n is a colimit cone. Lemma 2.4 then gives that .F(|J n Qn) — Un F(Qn)- C] 

When K in Proposition 2.8 is a category-cpo, we may regenerate the partial 
order on morphisms by taking T — S = i : C —> K, the insertion functor. We 
chose to introduce □ on morphisms beforehand in order to be able to partially order 
functors. 

Section 3. One-sorted Tries. 

We will need four particular category-epos for our application to tries, three 
which we introduce now, and a comma category-cpo to be named later. The first 
is the category-cpo (trivially one, because it is a epo) whose objects are sets and 
whose morphisms are only the inclusions between sets; we denote it by Seto The 
second is (Set*, C), the category-cpo of pointed sets, with an inequality taken to 
be any set inclusion A C A (provided this actually is a morphism of Set*, that is, 
provided A and A have the same base point). We will invariably call this category- 
cpo simply Set*. The third is Set® et *, the category-cpo of continuous endofunctors 
of Set* with their natural transformations; it is here that we hope to find the trie 
functor R. For now we identify one object of Set® et *: we denote by _L. the constant 
functor that maps every object of Set* to {•} and every morphism to !{«}• 
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We define the mapping of sets 


T(Z)= ZZ ki , 

2 = 1 

so that our word algebra T is given by T = \J n T^ n \$)- The monotonicity and 
continuity with respect to C of disjoint union (finitary or not) and finitary Cartesian 
product of sets are elementary facts—but for a proof of the latter, remove the spots 
in the proof of Proposition 3.3 below—hence these constructions are continuous 
endofunctors of Setc • It follows, by composition of functors, that T : Setc — * 
Setc is a continuous functor. 

We have to show that T, defined in Section 1 as the mapping Z i—► — l z f is a 
functor from Setc to Setf et * which preserves l.u.b.s as colimits, that there is a 
continuous functor 1Z : Setf et * — * Setf et * such that R n = 7?.( n )(_L.) and conse¬ 
quently R = U„, R (n) U.), that for every n > 0 there is a natural isomorphism 
7 n : 7£( n )(_L.) = jF(T^ n )( 0 )), and finally that the 7 n are the morphism parts of 
an ascending o;-chain of objects in a suitable comma category-cpo. We may then 
conclude that the morphism part of the l.u.b. is a natural isomorphism 

7 : R = (Jft( n >(_L.) “ JF(T), 

n 


and verify that 7 satisfies the equations given for ap in Section 1. 

The “finite functions” functor T 

For Z a fixed set, we may define what we will show is a continuous functor 
from Set* to Set* by the formulas, where A and B are any objects of Set* and 
h : A —+ B is any morphism, A » A‘ z > (taking the base point of Tv z ^ to be 
\z.* A ) and h ► (A f.h o /), which we correspondingly denote by h^ z f We may see 
that this is a functor by noting that its action on morphisms is that of a covariant 
hom-functor, or we may verify in detail 

l A W=\f.l A °f = \f.f = l Alz] 

(h O g) [Z] = A f.h ogo f = (A f.h O /) o (A f.g o f) = h [Z] o g [Z] . 

For continuity, we verify that — ^ is w-continuous on objects, i.e. that 

(i>»r=iK |zi . 

n n 


because first, all terms and the l.u.b. of any o;-chain -do C ^4i C ... (J n A n must 
share a common base point * in order for the inclusions to be base-point-preserving; 
second, if A C A', then an almost-everywhere-* function from Z to A is also such 
a function from Z to A', making — ^ monotone on objects, whence (J n A n ^ C 

(Un -^n) ) and third, if / G ((J n A n ) , then the finitely many non-* values of / 
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must already lie in some A n , whence (U n A n )^ Q [J n A n ^. To show that — 
preserves inclusions, calculate 

(A C A') [z] = A f.(A C A') o f = Xf e A^lf = (A™ C A ,[z] ). 

This shows that the functor — ^ is an object of Setf et *. 

We next show that the mapping Z i—► — ^ is the object part of a functor T : 
Setc — * Set* Set *, and that T preserves l.u.b.s as colimits. Note that T preserves 
a l.u.b as a colimit, but not as a l.u.b. Also, restricting its domain to Setc allows 
T to be covariant instead of contravariant. 

We first introduce some compact notation. Let Z C Z C Z be sets and let / E 
A^ be any function. We denote by f\Z_ the function \z € Z./(z) in A^, that is the 
restriction of / to Z, and by f]Z the function (Xz E Z. if z E Z then f(z) else *a) 
in A^\ The following facts are immediate: 


(1) nz\z = /\z ] 

(2) If {z e Z \ f(z) / * A } C Z, then f\Z\Z = /. 

For any h : A —♦ A' in Set*, 

(3a) (h o f)\Z_ = h o (/JZ), and 

(3b) (h o f)]Z = ho (/jZ) [because h : * A •—» *a'\' 

Let Zo C Z\ C Z <2 C ... be any sequence in Setc- For any / E ] e t 

rif denote the minimum index for which f\Z nf ] (J n Z n = /, that is, the minimum 
index such that f(z) = * A for all z E (\J n Z n ) — Z n/ . Then we may note the 
following facts: 


(4) 

For any n > nj, 

f\Z n 

. 'C 

N 

II 

and 




(5) 

For any h : A — 

-A', 


We may now 

define the functor T : 

Setc — 

+ Setf et * by 


T[Z) = - [Z] , 

T{Z C 2) = A Xf E A [z] ./1Z. 


To show that F(ZC-Z) is a natural transformation is to show that the following 
diagram commutes for any h : A —> A': 


A [Z] A [Z] 


Xf.hof 


Xf.hof 


A 




A 


>[Z] 
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But this is just Fact 3b: (ho f)]Z = ho ( f]Z ), for each / G A^ z \ 

We must check that T is a functor. It is immediate that T(Z—Z) — l_[z], the 
identity natural transformation. For a composite inclusion Z C Z C Z of sets, we 
have F(ZCZ) = P'(ZCZ) ■ P(ZCZ) because f\Z\Z = f]Z for any / € AS Z \ 

It remains to prove that T preserves any l.u.b. as a colimit. Let Zq C Z\ C • • • 

be any w-chain in Setc with Z = f (J n Z n . Fact A.3 gives that i* : Setf et * — ► 

Set!* Set *' creates colimits, and so by Lemma A.2 it will be sufficient to prove that 
i* o T preserves Z as a colimit. That is, for each A G Set*, we shall prove that 

with cone (A/ G A^ Zn \f]Z) n is a colimiting cone on the base A ^ hLIl^L, 

j^z{\ A /-/1-Z 2> ... To this end, let a = (cr n : Af Zi ^ —> X) n be any cone on the 
same base with vertex X. Let /i(<u) denote the morphism Xf.a Tlf (f\Z nf ) : A' z l — > 
X. We claim that ll((j) is the unique mediating morphism to the cone a, showing 
that A^ and its cone are a colimit. 

First we must show that fx(a) mediates: For any n and any / G A^ Zn \ let n' 
denote n^z- By its definition, n 1 < n. Since a is a cone, the following equation 
holds for f\ Z n > : 

(6) a n (f \Z n ')Z n ) = a n '(f\Z n '). 

By Fact 2, / = f\Z n >]Z n . By Fact 1, f]Z\Z n i = f\Z n >. Consequently, Equation 6 
is the required mediating equation as follows: 

(7) a n (f)=a n ,(f]Z\Z n .). 

Now to show uniqueness of /i(cr): Let g : —> X be any mediating morphism. 

For any / G A^ z \ since g mediates and since / = f\ Z nf j Z, the following equations 
hold: 

(8) 9(f) = g(f\Z nf )Z) = (g o (\f.f]Z))(f\Z n/ ) = a nf (f\Z nf ) = n(a)(f), 
that is, g = g,(a). 

It will be useful to spell out the effect of composite functors TZ\ o • - • o TZ^ 
on morphisms of Set* and of composite natural transformations T(Z\<AZ\) o ■ ■ ■ o 
f(Z k CZk) on objects. Restating the definition of T somewhat redundantly, we 
may write, for any one set Z G Setc, for h : A —> B in Set*, for / G A^ z \ and 
for z G Z, 

TZhfz = h(fz). 

This is the case k = 1 of the following generalization to composites: 

Proposition 3.1. For Z\, , Z k G Setc, for h : A —* B in Set*, for f G 

A^y" {Zl \ and for z\ G Z\, ... z k G Z k , 

(9) [TZi o • • • o TZ k )hfzi • • • Zfc = h(fz 1 • • • z k ). 

Proof. By induction on k. For k = 0 we have / G A, the composite functor is the 
identity /set,, and (9) is simply 


Iaet.hf = hf. 
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For k > 1 we have 

\TZ\ o • • • o TZ k \hfz x ■■■z k = \TZ X o • ■ • o PZ k ^ x ](PZ k h)fz x ■ ■ ■ z k _ x z k 

= TZ k h(fz 1 • 

= h(fz x ■ ■ -z k ). □ 


Formula 9 should be familiar from the theory of combinators: it gives the effect 
of fc-fold iteration of the composition combinator B. 

We may similarly write out the definition of ZC-Z ), for ZClf Setc, for 
A £ Set*, for / <E A^ z \ and for z £ Z: 

nZCZ) A fz = (f]Z)z. 

Again, this is the case k = 1 of a generalization to composites: 

Proposition 3.2. For Zi C Zi, i = 1 for A £ Set*, for f £ A 

and for z x £ Z x , ... , z k £ Z k , 


\T{Z X (£Z X ) o • ■ • o P(Z k CZ k )] A fz x = (f]Z x )z x ■ ■ Z k )z k . 

Proof. For k = 0, whence f £ A, the composite natural transformation is the 
(horizontal) identity, ls e t, : /set, —> Iset,, and the asserted equation is merely 

(lset ,)a/ = 1 a/ = /• 

For k > 1, write as a shorthand S for TZ X o • • • o fFZ k - 1, 5 for .FZi o • • • o TZ k _ x , 
and cr for o • • • o P(Z k - X CZ k ^ x ) : 5 —> 5. Then 

[cr o P(Z k CZ k )\ A f Z X ■■■Z k = [S(P(Z k CZ k ) A ) o <Jf(z k )A}fz 1 ■■■Zk 

= S(P(Z k CZ k ) A )(o^^ Zk ) A f)zi • ■ ■ z k 
= ^{Z k QZ k ) A (o^ Zk ) A fzi ■ ■ ■ z k -i)z k 
= ((<7F(Z k )AfZl ' ■■Z k - 1 )]Z k )z k 
= ((■■■ if]Zi)z x ■■■] Z fc _i)z fc _i1 Z k )z k 


respectively by definition of horizontal composition [7, p. 43 eqn. (2)], by definition 
of function composition, by Proposition 3.1, by definition of J r (Z k CZ k ) A , and by 
induction. □ 

Products and the functor 7 Z 

m 

We recall from Section 1 the definition of the modified Cartesian product, 
of m sets with base points, for any m > 0: 

m m 

n.* = n^-{<*A,>£i>u{.}. 

1=1 % — 1 
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m m 

We take it to be so clear as not to need a written-out proof that and fl# are the 
object parts of two m-ary product functors on Set,, naturally isomorphic via the 
evident 


771 771 

—• : n A{ ► 17, Ai 
2=1 2=1 

: {ai)fL 1 i—* otherwise, 

771 

and that the action of J"J. on morphisms of Set™ is given by 


771 

(n. ^0 (®1 ) ' • ' 5 ^771 ) = (/ll (fll) J . . . J ^771 (®771)) * 


1 — 1 


771 771 

Note that Yi. hi is a base-point-preserving map, as is hi (same definition without 

i=l i =1 

771 

the spots); also that we have defined exactly one value of Yl m hi for every element 

i=i 

771 

^ n. Ai, because —* is a one-to-one correspondence. We will similarly take the 

2= 1 

liberty of writing A-abstractions, when convenient, in the form A{ai,..., a m ) # . 

771 

We give the proof of continuity of H, as a reminder that the restriction to finitary 
products is essential: 

771 

Proposition 3.3. H« ; Set™ —* Set, is a continuous functor. 

Proof. We prove first ^-continuity on objects. For i = 1,..., m, let A^ C An C • • • 
be an ascending w-chain in Set* (necessarily sharing a common base point). Then 

m i i .I 

n. A in = { ( a l, • • • , Sm) | (Li £ (_J A in , L 1, . . . , ?7l} 

71 71 

— {(ai, • • • ? dm) I 3?7-i * * • . Ui G A * • * A ct-m, G } 

— {(^1? • • • ? ®m) | • &i ^ i 15 • • • j 

i i m 

= U n. A in- 

n i=1 

Then, to show preservation of inequalities, suppose that Ai C Ai, i = 1,..., m, 
and recall that as a function, an inclusion sends any element of Ai to itself as an 
element of Af, hence we may calculate 

771 _ / 771 771 _ \ 

n.(^<=AU) = A(ai,..., dm) • (cti,..., dm, ) — ( Ai ^ Ai J. D 
i=i \=i i=i ' 


771 

The finite products in Set* given by yield—see, for example, [7, III.5 ex. 5]— 

a “pointwise” product of any m functors G x , ... , G m G Set* et * which we denote 
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m 


by ii. 

i—1 


m 

(II. G i)A = Y[.(GiA) , 

K l~l 7 2 = 1 

m 

(n.Gi)A=n.(G,h). 

\=i J i =i 


Moreover, it is immediate that fj. Gi is continuous because is and the G; are; 

i — 1 

thus Setf et * has finite products. 

m 

Now it follows, by [7, III.5 Proposition 1], that Jl # is (the object function of) 
an m -ary product functor in Setf et *; the arrow function also works “pointwise”: if 
Ti : Gi —-> Hi, i = 1 ,..., m, then 


. in 

11. nA = n.M) for each A G Set*. 

i = 1 i— 1 

Finally as to products, we have 

m 

Proposition 3.4. : (Set* et ’) m —> Setf et * is continuous. 

Proof. Continuity on objects: For i = 1,..., m, let Gio C G,i C • • • be an w-chain 
in Set* et *. Then for each object A of Set*, 


(n, U Gin ) a — n, (u Gin) a = n. (U Gi n A) 

i— I n i=l n i 1 n 

m . m 

= U n. G in a = [j ( n. G in a) = (u n. g^ a, 

m % “ 1 Art % — 1 


and for each morphism h : A —> B of Set*, we may make an identical calculation 

m 

with h replacing A throughout. (For the central equality, recall that as a 
continuous functor, preserves l.u.b.s of cj-chains of morphisms as well as of objects.) 

Preservation of inequalities: If Gi C Gi, i = 1 then for each object 

A G Set*, 


771 

/ . _ \ m . m 

V i=1 ' i= 1 i=l 

771 771 771 m 

= (n. G^c n. Gix)=((n. g ( )^ ic (n. g ( )/ i)=(n. G f c n. g.)a □ 

7—1 X — 1 X —1 %—1 X —1 X —1 
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We are now in a position to observe that the functor 7 Z : Set* et * —* Set* et *, 
although most perspicuously defined pointwise: 


m 

(7 ZG)A = n.G (fci) i4, 

i— 1 
m 

(KG)h = Yl 9 G™h; 
2=1 


m 

(7 It) A = n. T^A, 
2 = 1 


may in fact be built by composition from the continuous functors and fc;-fold 
iteration: 

m m 

■RG = U.G {ki) 7er = n.'T (fci) 

2=1 2=1 

and is therefore itself continuous. 

Laws of exponents as natural isomorphisms 

We turn next to the reinforcement of Propositions 1.1 and 1.3 with categorical 
sinews. 

m 

Proposition 3.5. The one-to-one correspondence p^ : A\ Xi ^ = x d Q f 

2=1 

Definition 1.2 is natural in A (regarded as an object of Set*) and in X\, ... , X rn 
(regarded as objects of Setc)- 

Proof. We show naturality in A first; that is, for fixed sets Xi, ... , X m and any 
morphism h : A —* B in Set*, that the diagram 

fj.AW 

2=1 

/,cr=, 

fj #5 [wi £i£r =1 wi 

2 = 1 

commutes. (For compactness, we shall omit writing object arguments such as A 
and (Xi,. ..,X m ) for aO- 

772 

We may write out the definition of p^ : ^[Ai] — ¥ x d explicitly: 

2=1 

h'mifl, ■ ■ ■ , fm)' = A (l,x).fiX. 

Then, for any g\ G A^ Xl \ ... , g m G A^ Xm \ 

m 

[/C 0 n. h[Xl] ] ( 9i , ■ • •» 9rn)* = ^{ho gi,...,ho grn ) m 

2=1 

= X(i,x).[ho gi](x), 


n.h [x ' 



° Mm] (9li • • • ) 9m) 


fiEi=1 x d (A(z, x) .gix) 
h o (A (i,x).gix), 


and 
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which is the same function. 

This has shown naturality in A, that is, for fixed X\, ... , X m , that 


Mm 


m 


Now for naturality in X\, ... , X m we need, supposing ^ C for i = l,...,m, 
commutativity of 


n. a ix<] 

i— 1 

rrt _ I 

n. a/./i^ 




■> 


dEr=i *i) 


A/./1 E Xi 
1 = 1 


m _ „• 

a™ — > iEr=i *d . 

i=l 


For gi £ A^, * = 1,..., m, we find 


Mrn 0 n. A/./1XJ (<?!, . . . = Mm tell *1, • • • = A<», x).( 9i ] X t )x 

= (\(i,x).gix)]J2?=iXi = [(A/./1 °Mm]tel»-*-»^m) # - □ 


i—1 


[2 1 fc 

Proposition 3.6. The one-to-one correspondence v k ■ A^ Zk ^"' 1 = ^4tn i= i G f 

Proposition 1.3 is natural in A and in Z\, ... , Zk for any k > 0; that is, u k is a 
natural isomorphism of functors from Set£- to Set* et *. 

Proof. Recall that for g £ Af Zk ^ we have 


Vk(g) = \{zi,...,z k ).gz 1 ---z k . 


We first show naturality in A, that is, that for fixed Z\, ... , Z k £ Setc, and 
h : A —► B in Set*, the diagram 


A [Z k ]-[Zi] ^ , ^Z.x-xZk] 


\f\zi...\z k .h(fz 1 -z k ) 


\f\z.h(fz) 


B [ Zk )-.[Zd ; glZ^-xZA 


commutes. (As with Mm in Proposition 3.5, we have not written object parameters 

for u k . The label on the left side arrow comes from Proposition 3.1.) For any 
\^1 ] 

/ £ A^ Zk f" 1 , this works out to the true equation 


A(zi,..., z k ).h(f zi • • • z k ) = h o (A(zi ,..., z k ).f z 1 ■ ■ ■ z k ). 


Thus v k : TZ\ o • • • o TZ k T{Z\ x • • • x Z k ) is natural. 
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Now for naturality in Z\, ... , Z k , suppose C Z{ for i = 1,..., k, and for 
any A G Set, consider the diagram (the label on the left side arrow comes from 
Proposition 3.2): 

A [Z„]-lZi] v h > A [ Zl x-xZ k ] 


(/I Z 1 )z 1 ---fZ k )z k 


Xg.g](ZxX-xZ k ) 


A&t ]"' [Zl1 Vk > #x-x2i] i 


To show commutativity of this diagram is to show, for any / G " 1 , that 


. .,z k ).(- ■ -{f]Zi)zi- ■ -]Z k )z k = (\{zi,...,z k ).fzi---z k )](Z 1 x x Z k ). 


For any fc-tuple (z\,...,z k ) G Z\ x ••• x Z k , both sides of this equation yield 
f z\ • • • z k . On the other hand, if (z\, ..., z k ) G Z\ x • • • xZ k — Z\X ■ • • xZ k , then 
the right-hand side of the equation yields *a- Let j be the smallest index such that 
Zj G Zj — Zj‘, then the left-hand side also is 


‘)1 Zj+i)zj+i • • • 1 Z k )z k 

(""’((+1 • • • ^Z k ■ * A ) 1 Zj Al)ZjAl ' ' ’ 1 Z k ) Z k 
= * A . □ 


Combining the results of Proposition 3.5 and Proposition 3.6, we obtain: 

r g i j 

Proposition 3.7. The mapping ip kl ... kni , given for gi G A\ Zik ^ %1 (i = 1, ..., m) 
by 

V’fci ■■■km (ill? • • • ) 9m) 'Mb ( Z 1) • • • ) Z ki ) ) -Qi Z\ • • • Z ki , 

is an isomorphism 


V’fcl-fcm 


: ff. A^ Zik i^"' = A^?= 1 LIj=i z o\ 

i =1 


natural in the ki + • • ■ + k rn sets Zjj and in A. 

Proof. When natural isomorphism p* n (Proposition 3.5) is written without parame¬ 
ters, we have the following explicit expression giving functors from Set™ to Set® et * 
as its domain and codomain: 


/C: = 


Here J- m denotes T x • • • x T with m factors, and ^ denotes the m-ary coproduct 

ki 

functor in Setc • Consequently, writing J] for ki -ary Cartesian product in Setc, 


fej km • fcj fern 7H fcl fcm, 

° (n x • • • x n): n. ° ° (n x • • • x n) = ^ ° e °(n x • • • x n) 
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is a natural isomorphism of functors from Set^- 1 x • • • x Set^ to Setf et *. 
Similarly Proposition 3.6 gives, for i = 1, ... , m, 


»k % : (°ki) °F ki =^ 0 11 , 

displaying two functors from Set to Setf et * as explicit domain and codomain for 
u ki , and so we have by composition and m-ary product the natural isomorphism 


?Tl T71 771 

n.°Kx--x^ m ): x---xo fcm ojrfc-) * n.o(^ori x 


x 


fo-m 

^°rp 


again of functors from Set^ 1 x • • • x Set^ m to Setf et *. Here the natural isomorphism 
v kl x • • • x v km is defined to be the componentwise mapping 



{yk i Pi? • • • ? k'kjn ^m) 


where each Yj is a Aij-tuple of sets. 

But 

ki k m fcl k m 

T m o (n x • • • x n) = ° n* • • • x ? © n), 

so the above two natural isomorphisms are composable, yielding 

, , m 

ir K l K m 

(io) V’fci-fc™ = (fC ° (n x • • • x n)) • (n. ° {y kl x • • • x *0) 

m m hi km 

:n.»K»^x-x«f?‘-)=-f«E»(nx-xn)- 

Reverting to consideration of arbitrary objects Zij , j = 1 ,..., ki, i = 1,..., m 
of Setc and A of Set*, we may work out the effect of 4’k 1 --k m (((Zij)j t =1 )^L 1 ) A 

m [Z‘i] 

on any element (<71 ,... ,g m ) 9 of A'- Zik ^ 11 (as usual we suppress the object 
arguments): i=1 

^Pki ■■■k m {9li ■ • • ? 9m) = ^mi^ki 9li • • • ? k k m 9m) 

= lfm(HzU---,Zk 1 ).g\Z 1 ---Z kl , ..., \(z 1 ,...,Z km ).gmZi---Z km ) m 
= X(i, (z 1 ,...,z ki )).g i z 1 ---z ki . □ 


Construction of 7 as a least fixed point 

In developing ip k 1 ... km , we deliberately made provision for k\ H- \-k m separate 

sets Zij-, this was with an eye to facilitating the treatment of many-sorted term 
algebras in Section 4. Our need at the moment, however, is to come down to one 
set Z. We note the following fact about diagonal functors. For any functor F and 
any k > 0, 


(11) 


F k o A fc = A fc o F. 
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Now observe that we may express our term-algebra functor T : Setc —> Setc 
as 

m ki km 

T =E°(n x ---xri ) 0 ( A fci x • • • x A fc j © A m 

and the trie-building functor 77: Set* et * —> Set® et * as 


m 

n = tl,° (°fc i X ’"XOjeJo (A fcl X • • • X A fcm ) O A m 


Using Equation 11, we may express the composite 77 o T as 


7t°T = n. ° (o fcl x • • • x o km ) o (P kl x 

m 

= ii. ° ((°fci °^ fci ) x ••• x ( o km o 


■ ■ ■ X P km ) O (Afcj x • • • X A* m ) O A m 
T km )) o (Afcj x ••• x A fc Jo A m . 


If we define the composite 

^ 0 ( A fci x ••• x A fcm ) o Am, 

then Proposition 3.7 and the explicit expression for the type of given by 

Formula 10 yield 

Proposition 3.8. We have the natural isomorphism of functors from Setc to 
Set* et * 

: 77 o JF =* p oT. 

m 

For Z € Setc and A G Set*, the effect of ^ z a '• 
given by ?,_1 

= A (i,{z i ,...,Zk i )).giZ 1 ---z ki . □ 

We may now begin the construction of 7 : R = P(T). For brevity write X for 
the identity functor / g t set,. Define what we will show in a moment is a continuous 
endofunctor of X[P by 

C : J|J F —► X[P 

:(G,Z,r :G —4 .FZ) (77(G), T(Z), z • 77(r)} 

: (cr: G — G', (Z C Z)) . (R(<r), (T(Z) C T(Z))). 

Note that • 77(r) is an isomorphism if r is. 

By Lemma A.5, C is a well-defined functor, taking D = J, E = P, G = R = 71, 
p = Ik, H — T, and cr = ^ in the statement of the lemma. 

Recall (from Proposition 2.10) the forgetful functor P : IIP —■> Setf et * x Setc- 
Since 77 and T are continuous, P o C = 77 x T is continuous. Consequently, 
Proposition 2.10 gives that C is continuous. 

Now we will construct a least fixed point (R, T, 7) of C. The functor X. is initial 
in Set* et *: for any G G Set* et * we have the unique 


(A 1 —* (• 1 * *g(a ))) : -L. —* G . 
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JF(0) is also initial, as shown by the natural isomorphism 

7o = f (-4 i —* (• i—► Ax £ 0 . *a)) : X. = .T(0) • 

By initiality, and the fact that every 1Z(G)(A) is a spot product, and so contains 
•, we have the commutative diagram 


( 12 ) 


±. 
7o 

m) 


^(8cr{0)) 


K(±.) 

^ 0 ' 7 ^( 70 ) 

Jf(T(0)). 


Let Rq = X. and To = 0. For brevity, write □ for the inequalities (C, C) of ZJ..X. 
Then ( 12 ) is 

(To, To, 70 ) E C(R 0 , T 0 , 70 ) 

drawn as a diagram in Setf et *. It allows us to generate the ascending w-chain in 

IIR: 

(13) (T 0 ,T 0 ,7o) E (Ti,Ti, 7 i) C (T 2 ,T 2 , 72 ) E ••• 

where (R n ,T n , j n ) = C (n) (T., 0, 70 ) or, in detail, 

Rn+l = R(Rn), T n+ 1 = T(T n ), 7„ + l = • T( 7 n ) . 

Then Proposition 2.8 gives that (13) has a l.u.b. (T, T, 7 ) where R = (J n T n , 
T = (J n T n , and (since, by induction, each -y n is an isomorphism) 7 : R = T(T). 

Considering C merely as an ^-continuous mapping on the objects of TfT, we 
have found 

(T,T,7) = |JcW(T.,0,7o). 

71 

We pause to note the following fact about epos, useful for finding least fixed 
points when there is no least element. 

Fact 3.9. In any epo K, if a function F : K —> K is u-continuous, and if k £ K 
is such that F(k') □ k for all k', then |J ri F (n )(k) is the least fixed point of F. 

To see this, recall the familiar fact that |J n F^ n \k) is the least fixed point of F 
above k ; the hypothesis ensures that every fixed point of F is above k. 

Now we may observe that X. C R(G) for every G £ Set® et * and 0 C T(Z) 
for every Z £ Setg, so the initiality of X. gives that (X.,0,7o) E C(G,Z,t ) for 
every (G,Z,t) £ T\T. Hence, by Fact 3.9, (R,T, 7 ) is the least fixed point of C. 
Moreover, if (R, T, 7 ') is any fixed point of C connecting R to T, then Fact 2.9 gives 
that 7 ' = 7 . In other words, 7 is the unique natural transformation from R to 
T(T) satisfying 


7 = ■ 
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(The uniqueness of 7 can be proved using only the initiality of (Ro, To, 70 ) [3, 
Proposition 2.31], but the partial order in XjF simplifies the proof here. Reynolds 
noted a similar uniqueness for the relational functor which he constructed in [ 10 ].) 

Recovering the look-up algorithm 

We may now unpack the fixed-point equation characterizing 7 to recover the 
look-up algorithm “ap” which was written down but not justified in Section 1 . 
Let A G Set* be any pointed set and let (ri,..., r m ) # G R(A ) be any T-indexed, 
71-valued generalized trie. We have 


7a(»T, • • •, I'm)* = ('Lt • n.7 (fc,) ) A (i'i, • • •, r m )* 

i=l 

rri 

= {^TA o n.(7 (fc,) U) (ri,..., r m ) # 

i =1 

= (Mgi, ■ ■ ■, 9m)' ■ A(i, (ti,...,t ki )) .gih’-’tk.) 

(14) = X(i, (ti,... ,tki)) ■ in {ki) ) A riti---t ki . 

Recall that for any functors F,G : M —» L and F',G' : L —> K and any natural 
transformations r : F G and t' : F' —^ G", the horizontal composition 
t' o r : F' o F —* G' o G is given [7, p. 43 Formula 3] by 

t' o t = ( G' o r) • (t 1 o F). 

For endofunctors F,G : L —> L, t : F —> G , and any k > 0 , this yields by an 
easy induction the formula for : F^ 

(15) r (fc) = (G (fc_1) o r) • (G (fc ~ 2) o r o F) •... • (G o r o F (/c “ 2) ) • (r o F (fc_1) ). 

So for any k > 0 and r G R(*4(.A), we have, since 7 ^ : R( fc ) —^ Fj^, 

(7 (fc) )A r = [(4 fc_1) 0 7) • (4 fc_2) o 7 o R) •... • (F T o 7 o R( fc - 2 )) • (7 o R^)] A r 
= [C^t -1) (7a)) o (Ft _2) (7r ( a))) 0 • • • 0 (Fr(7fl0=-2)(A))) °7i?(^-D(A)]i' 

= F?- 1 ) (7a)(F^- 2 ) ( 7 r(A))(- • ■ (^r(7iK‘-«(A))(7iK*-i)(A)r)) •■■))• 

From Proposition 3.1 we have, for any j > 0, for an appropriately typed morphism 
h of Set* and function /, and for ti, ... , tj G T, 

F^hft 1 ■■■tj = h(fti ■ ■ -tj ). 


Let £ 1 , ... , t k be any terms, and apply this in turn for j = k — 1 , k — 2 , ... , 1 , 
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yielding 

{^ k) ) A rti ■■■t k 

= ” 2) (7r(A)X- ' • (^t(7ro-2)(a))(7r(*-i) ( a) 0) '' -))*i ’■■tk 

= 7 a(^t _2) (7r(A))(- • • (•^r(7i?(*=-2)(A))(7i?(^-D(A) r )) • ■ 0*i • "t k -i)t k 
= 1a(1R(A)((- ■ • (•^r(7R('=-2)(yi))(7R(fc-i)(A) r )) • • -) f l • ■ ■ tk-2)tk-l)tk 


= 1a{1r(A){- ■ ■ (^T(7RO-2)(A)X7RO-i)(A) r )M2) ' ' -)t k -l)tk 
= 1a(1r(A){ • ■ -7ii(k-2)(,4)(7fl(*-i)(A) r *l)*2 • • • )tk-l)tk • 


So Equation 14 becomes 

7 a(fi, . .. ,r m ) # = A(», ■ 1a{1r{A){- ■ ■ (7jK*-D(A) r <i) ‘ ‘ -)hi-i)t ki ■ 

Since 7^4 is base-point preserving, we may expand this as 


7a • = *.Am = Xt .* A 

7A(ri,...,r m ) = . 7a(7r(A)(' • • (7fi(*-D(A) r *i) • •' )^-i)<fci • 

This is precisely the recursive definition proposed in Section 1 for ap. 

A more realistic set of terms 

In a typical application of generalized tries, such as to a table of common sub¬ 
expressions in a compiler, one would be likely to find that the “terms” to be looked 
up were not quite an instance of the term algebra T we have been discussing, but 
rather were defined by an equation like 

rpt _ rp/k\ _|_ rp/km ^ y 

with E being a large, possibly infinite, set of unstructured elements such as iden¬ 
tifiers or numerals. We sketch here how any reasonable (that is, functorial) data 
structure for E-indexed look-up tables can be incorporated with the trie idea. 

Suppose then that T' is as just described, that is, the least fixed point of a 
functor T' : Setg —* Setg defined by 

T'(Z) = Z kl +-f Z km + V. 

We suppose that a functor B : Set* — » Set* encapsulates some data structure for 
E-indexed tables, its look-up function being a natural transformation ft : B — > 
(For example, B might assign to each pointed set A the set of all E- 
indexed, A-valued binary search trees. With such possibilities in mind, we refrain 
from supposing that ft is an isomorphism, which would be to suppose a unique 
representing data structure for each finite function.) 
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The elements of R'(A ), the T'-indexed, A-valued tries, will correspondingly have 
an m + 1st field in each tuple, containing an element of B(A) or of B(R f (A )) or 
.... That is, we define 

n'(G) = G {kl) x. • • • x. G {km) x. B , 

7 Z’(t) = x. • • • x. x. 1 B . 

Suitable adjustments to the constructions used for Propositions 3.7 and 3.8 above 
will then produce a natural transformation (not an isomorphism unless (3 is) 

: R! o T —■* T o T', 


with the effect of 




ZA 


i =1 


?Y3T=\ z k i+viA) 


given by 


*ZA(9l>-,9m,b)' = 7C + l<"fci (01 ),•••, »k m (9m), Pa(V))* , 

that is, 

W’za (9u • • • , 9m, b) 9 (i, (zi,. .., z ki )) = g { z x • ■ ■ z ki if * < m, 

l,v) = p A bv. 

The construction of C : TfjT —► T[T and its least fixed point (R!,T','y'), with 
7 ; : R' —-» T(T') and 7 ' = ^f' T , ■ TZ'(Y), may then proceed as before. 

Section 4. Many-sorted Tries. 

In extending the result of Section 3 to many-sorted term algebras the greatest 
difficulties are notational. For many-sorted algebras we follow Goguen, Thatcher, 
Wagner, and Wright [5] in substance, although our notion of signature is arranged 
differently from theirs in order to follow our treatment of the one-sorted case more 
closely. 

Let S be a set of “sorts”. We call a finite sequence of sorts, that is an element w of 
5*, the free monoid over S, a “word” on 5; we denote its length as |ru|. A signature 
for an 5-sorted algebra should provide for each operator a result sort and a finite 
sequence, that is a word, of argument sorts. It is necessary to our trie construction 
that for each s £ S, only finitely many operators have result sort s (this is our only 
substantial departure from the notion of 5-sorted algebra in [5]). Accordingly we 
suppose that an 5-sorted signature is a pair (m, k) where m is an 5-indexed family 
of non-negative integers and, for each s € 5, k(s) : (l,...,m(s)} —* 5*. For 
s £ 5, m(s) is the number of operators having result sort s, and for 1 < i < m(s), 
n(s)i gives the arity (a word on 5) of the ith operator of result sort s. 
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To give as familiar an example as possible of a two-sorted term algebra, we take 
ordered trees and ordered forests, with the tree nodes again labeled by a single bit; 
the mutually recursive definition is 


T t = T f + t f , 

2f = {()} + Tr x Tp . 


We would like the Tt- and Tp-indexed tries to come out satisfying the corresponding 
equations 


i?x(A) = -Rf(A) x Rp(A'), 

— Ax R r F {RF(A)). 

As is well known, ordered forests are in one-to-one correspondence with binary 
trees. Following the example may be facilitated by observing that a Tp-indexed 
trie comes out as a reformatting, via the template { , , } t—> ( , ( , )), of a 

Tp-indexed one-sorted trie. 

The same two-sorted syntax of terms may be expressed more opaquely according 
to our definition of many-sorted signature by the choices S = {t, f} (for “tree” and 
“forest”, not the truth values), w(t) = m(F) = 2, k( t)i = k( t) 2 = F, k(f)! = e 
(the empty word), and k(f )2 = TF. 

We follow [5] in a convenient generalization of the exponential notation: if X is 
an 5-indexed family of sets and w € S* is a word, w = W\W 2 ■ ■ - Wk say, then X w 
denotes X(wi) x • • • x X{wk). 

Fixing now on any arbitrarily chosen S, rn, and k, we may make the construction 
of the term algebra look very much like the one-sorted case. Define the functor 
T : Set^ —» Set^ by, for each s € S and Z € Set^, 


T(Z)(s) 


m(s ) 




7 = 1 


Then let T € Set^ be given by 

T = |jT (n) (AseS.0). 

71 


(Slightly abusing notation, we write plain C and |J for the componentwise extension 
of inclusion and union to 5'-indexed families of sets. In particular Z C Z’, where 
Z and Z’ are S'-indexed families of sets, if and only if Z(s) C Z'(s) for all s G S. 

Analogously we extend C and (J to S'-indexed families of functors.) 

Similarly generalize the notation for n-fold composition: if G is an S'-indexed 
family of endofunctors of Set*, that is an object of (Set® et *) , and it; is a word 
on S with |it;| = k , let C?W) denote G(w i) o • • • o G(wk)- Likewise, if r is an S- 
indexed family of natural transformations of such functors, that is a morphism of 
(Setf et *) 5 , let r(W denote t(wi) o ■ ■ ■ o r(wk)- 
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Now we may define R , the T-indexed trie functor, much as before: 

R = \Jn in) (Xs e s. _l.) 

n 

where 7 Z : (Set* et *) —» (Setf et *) is given, for objects and morphisms G and r 
of (Set* et *) 5 and for s G S, by 

ra(s) m(s) 

^(C( s ) = n. GWs)i) > = n.r(-wo. 

2—1 2—1 

There is nothing new in the verification that T and 1Z are continuous endofunctors 
of Set^ and (Setf et *) respectively. 

The sets of terms and of tries which for readability we called Tt, etc. have official 
designations T(t), etc. 

Using the notation of [7, p. 45], we have the continuous functor 

T s : Set? — (Setf et *) 5 , 
f s (Z)(s)=F(Z(s)), 

T S {Z C Z')(s) = T(Z{s) C Z'{s)), 

for 5-indexed families of sets Z, Z' and for s G S. 

Applying once more the notational idea from [5] of generalizing from non-negative 
integers to words, we may, for any category L and w G S* with |tw| = k, define 

: L s —» L k , 

A w (x) = (x(wi),. ..,x(w k )) 

for both objects and morphisms of L s . As earlier with A n , we shall leave the 
category L to be determined by context. 

Now, combining for each result sort its own version of the natural isomorphism 
ip kl ■■■k rn introduced in Proposition 3.7, we may define a natural isomorphism T of 

functors from Set^ to (Set* et *) S , 

¥ : ft o F s ^ T s o T, 

by, for any Z G Set$ and s G S, 

^ z( s ) = [V’|«(s)i|---|/c(s)- sr ( s )| 0 (A k (s)i X X A k ( s )_ (s) ) O A m(s)]z 
: H(T s Z){s) S5 T s (JZ)(s ) = F(TZ(s)). 


For A G Set*, the effect of 41 z(s )a is given by 


i = 1 i= 1 ^ i=1 

^ z(a)a{91i • • • •> 9m(s)) (^ 1 , • • • , |)) • 9i . 
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S 

Write X s for the identity functor on (Setf et *) . Then we may define a contin¬ 
uous endofunctor of the comma category X s [X s by 

C : X s [X s —+ X s [X s 

'• {G, Z,t : G —> X s Z) i ^ (K(G),T(Z),* z ■ TZ(r)) 

: (a : G —> G', (Z C Z')) — (ft(<r), (7(Z) C T(Z'))> . 

Lemma A.5 shows, taking D = X s , E — X s , G = R — TZ, p — 1 ^, H = T, and 
a = St, that C is a well-defined functor; C is continuous because 72. x T is. 

The ^-indexed family _L. = f As . _L. is an initial object in (Setf et *) 5 , and we 
have the natural isomorphism 

7 0 = f As . 70 : X. = As . X($). 

We obtain, as in the one-sorted case, 

( J R,T,7) = |JC (n) (X.,As.^(0),7o), 


with 7 a natural isomorphism, and the unique natural transformation satisfying 
7 = y T .n(i). 

To uncover the look-up algorithm in 7 , we may begin by writing an analogue to 
Formula 14, for s G S, A G Set*, and ( 77 ,.. .,r m ^) G i?(s)(A) any T(s)-indexed, 
A-valued trie, 

(16) 7(«M»T, . . . , ^m(s))* = A(i, (ti, .. • , t\K(s)i\)) - (7 ( " (s)i) )A^ ti • ■ • t|«(,)i| • 

The formula for horizontal composition generalizes just as well to k pairs of functors 
which need not all be the same; so for any category L, any two S'-indexed families 
F and G of endofunctors of L , that is any two objects of (L l ) s , any morphism 
r : F —A G of (L l ) s , and any w G S* with j w j = k we have the 5-sorted analogue 
of Formula 15: 

T (w) = (Qiwx-w*-!) Q r ( Wfc )) . o r(tw fc _i) O F^ Wk) ) ■ ... 

... ■ (G (W1 > o T (w 2 ) o F^ w 3 - Wk) ) ■ (r(wi) o F^ w *- w ^). 
Thus for r G R^ w \a) we have, since 7 ^) : R^ (X^)( w \ 

For any prefix w~ = w\ - • -Wj of w, for any morphism h : B —♦ B f of Set*, for 
/ G B^ r( ' w ^ ^ ^ and for t\ G T(w 1 ), ... , tj G T(wj), Proposition 3.1 yields 
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Then for A G Set*, r G R^ w \a), and U G T(wi), i = 1, ... , k, we obtain 

(¥ W) )Arh • • -t k = ^(w^A^Wk-l) R (™ k ) {A) ( ... 

'Y{ w 2 )^(“ 3 '" 1 "* ) ( j 4) " w k'>(A) r ^l) ^2 ' ‘ ‘ ) Afc—l) Afc • 

So we may write the S'-indexed family of mutually recursive routines implicit in 
Formula 16 as 

7 (s)a • = A te T(s). * A 

'7( s )a{ ? T, • • • ) r m(s)) = A(i, (tl, . . • , t|/c(s)j|)) - 7(( K ( 5 )i)|«;(s)i|)A( 

This is not really as horrible as the general notation makes it look. For our example 
of ordered trees and forests, calling the two look-up functions T-ap and F-ap rather 
than 7 (t) and 7 (f), it works out to 

T-ap^ • t = * A , 

T-ap A (ri,r 2 )(l, (/)) = F-ap^rq /, 

T-ap^(ri,r 2 )(2, (/)) = F-ap A r 2 /; 

F-ap A • f = *A, 

F-ap A (ri,r 2 )(l, ()) = r u 

F-ap A (n,r 2 )(2,(t,/)) = F-a Pj4 (T-a Pj?F(A) r 2 t) f. 

Appendix. Colimits in Comma Categories. 

Below are two theorems which show the creation of a colimit by parameters in a 
category of functors and in a comma category. The first is MacLane’s “(co)limits 
with parameters” theorem [7, Theorem V. 3 . 2 ] which we state here as a fact. The 
second is Bierle’s theorem, which shows how to construct a colimit by components 
in a comma category [ 1 , Fact 1.4]. This theorem was independently discovered 
by Connelly [3] and by Casley, et. al. [ 2 ], The presentation here uses MacLane’s 
concept of “creating colimits” [7, p. 108], defined as follows. 

A functor V : K — * M creates colimits for a functor F : J —*■ K if and only if 
for any colimit cone r : V o F —-> m there is a unique object A; in AT and unique 
cone a : F —> k such that V o a = r and, further, this a is a colimit cone. 

The functor V is often a forgetful functor, sending every morphism of K to itself 
as a morphism of M. In this case we may describe the creation of colimits by V for 
F as the existence, for any colimit cone r : V o F m, of a unique k G K such 
that Fk = m, and r : F —k is also a cone in K , and r is also a colimit in K. 
The definition of “creates colimits” yields the following obvious fact. 

Fact A.l. Let a : F —> k be a colimit cone created by V. For any cone rj: F —> 
k 1 , the unique mediating morphism (u.m.m.) f from V o o to V or] is the image of 
the u.m.m. g from a to rj (that is, Vg = f). 

In the case of V a forgetful functor, Fact A.l says that any u.m.m. in K from 
the created colimit o to another cone on F is the same as the u.m.m. in M between 
the composites of the two cones with V. 
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The next lemma gives a condition under which a functor that creates colimits 
can be used to prove that a second functor preserves colimits. 

Lemma A.2. Let F : J —■> K, G : K —► L, and V : L —* M be functors. If 

V creates colimits for G o F, and Vo G preserves colimits of F, then G preserves 
colimits of F. 

Proof. Let o : F —> k be any colimit cone. By hypothesis, V o G o a is a colimit 
cone. Since V creates colimits of G o F, Goa must be the colimit cone created by 

V for V o G o a. □ 

MacLane’s theorem gives a way to create a colimit by parameters in a functor 
category. It uses the following notation. Let \L\ denote the discrete category whose 
objects are those of L, and let i : \L\ —> L denote the insertion functor. Define 
i* : K L —> K\ L \ as the functor sending H t —> H o % for each object (functor) and 
rj i— > tj o i for each morphism (natural transformation). 

Fact A.3. [7, Theorem V.3.2] Let K and L be any categories. The functor i* : 
K l —> K \ l I creates colimits (for any functor F : J —* K L ). 

Lemma A.2 and Fact A.3 mean that for any functors F : J —* M and G : 
M —» K L , if i* o G preserves colimits of F, then G preserves colimits of F. This 
is especially useful because \L\ is discrete and so it is sufficient to show that i* o G 
preserves colimits for each object l of L. 

Beierle’s theorem uses the following notation. Let T : L —*• K and S : M —» K 
be any functors. For any object z G T[S, Zj will denote the morphism in z 
(i.e., the third component). Consider the following forgetful functor and natural 
transformation (the latter is taken from [1]). 

P : TiS —► L x M 
—♦ (l,m 
(u,v) I—♦ (u,v) 


P[ '■ T o III o P —*■ S o n 2 o P 
: z i—> Z| 


The composites Ffi o P and II2 o P will be abbreviated by Pi and P 2 respectively. 

Here is Beierle’s Fact 1.4. The statement of the theorem here is more detailed 
than the references [1, 2, 3], but the proof method is the same. 

Theorem A.4. Let T : L —* K and S : M —» K be any functors. Let F : J —> 
TIS be any functor such that T preserves colimits of Pi o F. Then the functor 
P : TIS —> L x M creates colimits for F. Specifically, if r : P o F ( l,m) is 

any colimit cone of P o F, then in the created colimit cone r : F —> (l, m, f), f is 
the u.m.m. in K from the colimit cone T o P 1 or to the cone (S o P 2 or) • (P| o F). 
Further, if S preserves colimits of P 2 o F, and P± o F is a natural isomorphism, then 
f is an isomorphism. 

Proof. Let t : P o F —* (l, m) be a colimit cone. Since T preserves i7i o r as a 
colimit cone, T o Ih o r is a colimit cone. Let / : T(l) —■> S(m ) denote the u.m.m. 
from T o Ffi o r to (S o II 2 o r) ■ (Pj, 0 F). That is, / satisfies the following diagram 
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for each j £ J. 


T(F(j) 1 ) 

- r(r0)l) > T(Z) 



f 

S(F(jh) 

-* S(m) 


S(r(jh) 


The diagram gives that r(j) is a morphism in TfS from F(j) to (Z,m, /) for each 
j £ J. Consequently, since r is a cone from PoF to (l, m ), it is also a cone from F to 
(l, m , /). To see that / is unique in the vertex (l, m, /), suppose (Z, m, f) to be any 
other vertex of r in T[S. For each j £ J , the morphism r(j) : F(j) —* (Z,m,/') 
implies that the diagram continues to commute if / is replaced by /'. Consequently, 
/' mediates from To Ffi o r to (So IJ 2 o r) • (Pj o F) and must be the u.m.m. /. When 
S preserves colimits of P 2 o F and P| o F is an isomorphism, (S o II 2 o r) • (Pj_ o F) 
is a colimit cone and so / is an isomorphism. 

It remains to prove that r is a colimit cone in TJ.5. Let a : F {l,rh,f ) be 

any cone and let v : (l, m) —* (I, rh) denote the u.m.m. from P o t to P o a. It 
must be proved that v is a morphism in T[S from (Z,m,/) to (l, m, /) and that it 
uniquely mediates from r to a. The only part of this that is any work is to show 
that v is a morphism at all, as follows. 

Since r(j) : F(j) —> (l, m, f) for each j £ J and since mediates from P 2 ° r 
to P 2 o cr, the following equations are valid for each j £ J: 

S(u 2 )ofoT(r(j)i) = S(u 2 )oS(r(j) 2 )oF(j) l = S(u 2 or(j) 2 )oF{j) l = S(a(j) 2 )oF(j) ^ 

Since v\ mediates from P\ o r to Pi o a and since a{j) : F(j) —> (Z, m,/) for each 
j £ J, the following equations also hold for each j £ J: 

/oT(q)oT(r(j)i) = /o T(v x o r(j)i) = f°T(a(j)i) = S(a(j) 2 ) o F(j) v 

These two sequences of equations show that S(v 2 ) o / and / o T(u 1 ) both mediate 
from colimit cone T o Pi o r to cone (5 o P 2 ° a) ■ {P[ o F) and so must be equal. 
Consequently, v is a morphism in T[S from (Z, m, /) to (Z, m, /). 

That v uniquely mediates from o to r is true simply because v uniquely mediates 
from P o a to P o r. □ 

The following corollary gives a condition under which a functor whose codomain 
is a comma category will preserve colimits. It is similar to Corollary 2.19.3 in [3]. 

Corollary A.4.1. Let H : Q —» TJ.S be any functor. For any functor F : J —> 
Q, if P o H preserves colimits of F and T preserves colimits of P\o H o F, then H 
preserves colimits of F. 

Proof. By Theorem A.4, P creates colimits of H o F. Take V to be P and H to be 
G in Lemma A.2; then H preserves colimits of F. □ 

The following diagram lemma for the construction of an endofunctor of a comma 
category, which we apply in Sections 3 and 4, generalizes a construction used in 
Chapter 7 of [3] that in turn was inspired by the relational functors defined by 
Reynolds [10]. It seems time it was recorded separately. 
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Lemma A. 5. Given five functors D : L — » K, E : M —> K, G : L — * L, H : 
M —> M, and R : K —> K, and two natural transformations p : D o G —Ro D 
and a : R o E —> E o H, the following defines a functor: 

C : DIE — ► DIE 

: (l, m i /) 1 * (G(l), H(m), <r m o R{f) o pi) 

:(g,h)^(G(g),H(h)). 


Proof. To see that C is a functor, consider any morphism (g, h) : ( l,m,f) —» 
(V, m' , f) of D[E as a commutative diagram in K: 


(*) 


D(l) — > D(V) 


f 


f 


E(m) -»■ E(m '). 

E{h) 


This is sent by C to the outer rectangle of the following diagram. 


D{G{1)) £)(G(g)) > D(G{V)) 


Pi 


Pl> 


R(D(l)) fi(P(g)) > R{D(V)) 


(**) 


R(f) 

R(E(m)) 


E(H(m)) 


R(E(h)) 


E(H(h)) 


Rtf') 

R(E(m')) 


EWm')). 


The upper pane of (**) commutes because p is a natural transformation, and the 
lower pane because a is. The center pane is simply the image of diagram (*) under 
R. Consequently, (**) commutes and C is well defined. C preserves identities and 
composition simply because G and H are functors. □ 

As we apply the lemma here, we have D always the identity Ik, with G = R 
and p = Ik, so that the definition of C reduces to 


C : I K IE — I K [E 

: i—> (R(l), H(m),a m o R(f)) 


:(g,h)^(R(g),H(h)). 
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